<!DOCTYPE html>
<html lang="zh-cn">
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1">
  <title>给Allegro增加一个JPEG库 - whowin - 发表我个人原创作品的技术博客</title>
  <meta name="renderer" content="webkit" />
<meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1"/>

<meta http-equiv="Cache-Control" content="no-transform" />
<meta http-equiv="Cache-Control" content="no-siteapp" />

<meta name="theme-color" content="#f8f5ec" />
<meta name="msapplication-navbutton-color" content="#f8f5ec">
<meta name="apple-mobile-web-app-capable" content="yes">
<meta name="apple-mobile-web-app-status-bar-style" content="#f8f5ec">


<meta name="author" content="whowin" /><meta name="description" content="Allegro本身不能对jpeg图片进行处理，比如把生成的图形存储成jpeg文件，所以给Allegro配上一个合适的jpeg库是很有必要的，本文详细介绍了如何在Allegro上安装一个叫做jpgalleg的jpeg库。本文是我2008年的作品，2023年重新整理发布，仅为存档，其中的程序并没有再次验证，特此说明。
" /><meta name="keywords" content="linux, socket, hugo, dos" />






<meta name="generator" content="Hugo 0.97.3 with theme even" />


<link rel="canonical" href="https://whowin.gitee.io/post/blog/dos/0013-install-jpgalleg-for-allegro-under-djgpp/" />
<link rel="apple-touch-icon" sizes="180x180" href="/apple-touch-icon.png">
<link rel="icon" type="image/png" sizes="32x32" href="/favicon-32x32.png">
<link rel="icon" type="image/png" sizes="16x16" href="/favicon-16x16.png">
<link rel="manifest" href="/manifest.json">
<link rel="mask-icon" href="/safari-pinned-tab.svg" color="#5bbad5">



<link href="/sass/main.min.e3fea119b1980e848b03dffbeddb11dd0fba483eed0e5f11870fb8e31f145bbd.css" rel="stylesheet">
<link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.css" integrity="sha256-7TyXnr2YU040zfSP+rEcz29ggW4j56/ujTPwjMzyqFY=" crossorigin="anonymous">


<meta property="og:title" content="给Allegro增加一个JPEG库" />
<meta property="og:description" content="Allegro本身不能对jpeg图片进行处理，比如把生成的图形存储成jpeg文件，所以给Allegro配上一个合适的jpeg库是很有必要的，本文详细介绍了如何在Allegro上安装一个叫做jpgalleg的jpeg库。本文是我2008年的作品，2023年重新整理发布，仅为存档，其中的程序并没有再次验证，特此说明。" />
<meta property="og:type" content="article" />
<meta property="og:url" content="https://whowin.gitee.io/post/blog/dos/0013-install-jpgalleg-for-allegro-under-djgpp/" /><meta property="article:section" content="post" />
<meta property="article:published_time" content="2008-05-15T11:42:58+08:00" />
<meta property="article:modified_time" content="2008-05-15T11:42:58+08:00" />

<meta itemprop="name" content="给Allegro增加一个JPEG库">
<meta itemprop="description" content="Allegro本身不能对jpeg图片进行处理，比如把生成的图形存储成jpeg文件，所以给Allegro配上一个合适的jpeg库是很有必要的，本文详细介绍了如何在Allegro上安装一个叫做jpgalleg的jpeg库。本文是我2008年的作品，2023年重新整理发布，仅为存档，其中的程序并没有再次验证，特此说明。"><meta itemprop="datePublished" content="2008-05-15T11:42:58+08:00" />
<meta itemprop="dateModified" content="2008-05-15T11:42:58+08:00" />
<meta itemprop="wordCount" content="1537">
<meta itemprop="keywords" content="DOS,DJGPP,ALLEGRO,jpgalleg," /><meta name="twitter:card" content="summary"/>
<meta name="twitter:title" content="给Allegro增加一个JPEG库"/>
<meta name="twitter:description" content="Allegro本身不能对jpeg图片进行处理，比如把生成的图形存储成jpeg文件，所以给Allegro配上一个合适的jpeg库是很有必要的，本文详细介绍了如何在Allegro上安装一个叫做jpgalleg的jpeg库。本文是我2008年的作品，2023年重新整理发布，仅为存档，其中的程序并没有再次验证，特此说明。"/>

<!--[if lte IE 9]>
  <script src="https://cdnjs.cloudflare.com/ajax/libs/classlist/1.1.20170427/classList.min.js"></script>
<![endif]-->

<!--[if lt IE 9]>
  <script src="https://cdn.jsdelivr.net/npm/html5shiv@3.7.3/dist/html5shiv.min.js"></script>
  <script src="https://cdn.jsdelivr.net/npm/respond.js@1.4.2/dest/respond.min.js"></script>
<![endif]-->

  <script async src="/js/busuanzi.pure.mini.js"></script><script async src="https://pagead2.googlesyndication.com/pagead/js/adsbygoogle.js?client=ca-pub-9724909319263152"
     crossorigin="anonymous"></script>


</head>
<body>
  <div id="mobile-navbar" class="mobile-navbar">
  <div class="mobile-header-logo">
    <a href="/" class="logo">WhoWin</a>
  </div>
  <div class="mobile-navbar-icon">
    <span></span>
    <span></span>
    <span></span>
  </div>
</div>
<nav id="mobile-menu" class="mobile-menu slideout-menu">
  <ul class="mobile-menu-list">
    <a href="/">
        <li class="mobile-menu-item">首页</li>
      </a><a href="/post/">
        <li class="mobile-menu-item">文章归档</li>
      </a><a href="/article-categories/categories/">
        <li class="mobile-menu-item">文章分类</li>
      </a><a href="/tags/">
        <li class="mobile-menu-item">文章标签</li>
      </a><a href="/about/about/">
        <li class="mobile-menu-item">关于</li>
      </a>
  </ul>

  


</nav>

  <div class="container" id="mobile-panel">
    <header id="header" class="header">
        <div class="logo-wrapper">
  <a href="/" class="logo">WhoWin</a>
  
  <div style="position:absolute; left: 80px; top: 75px; color: crimson">
      ———开源和分享是技术发展的源泉和动力；本博客所有文章均为原创
  </div>
</div>





<nav class="site-navbar">
  <ul id="menu" class="menu">
    <li class="menu-item">
        <a class="menu-item-link" href="/">首页</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/post/">文章归档</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/article-categories/categories/">文章分类</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/tags/">文章标签</a>
      </li><li class="menu-item">
        <a class="menu-item-link" href="/about/about/">关于</a>
      </li>
  </ul>
</nav>

    </header>

    <main id="main" class="main">
      <div class="content-wrapper">
        <div id="content" class="content">
          <article class="post">
    
    <header class="post-header">
      <h1 class="post-title">给Allegro增加一个JPEG库</h1>

      <div class="post-meta">
        <span class="post-time"> 2008-05-15 </span>
        <div class="post-category">
            <a href="/categories/dos/"> DOS </a>
            </div>
        
      </div>
    </header>

    <div class="post-toc" id="post-toc">
  <h2 class="post-toc-title">文章目录</h2>
  <div class="post-toc-content always-active">
    <nav id="TableOfContents">
  <ul>
    <li>
      <ul>
        <li><a href="#前言">前言</a></li>
        <li><a href="#1-下载jpgalleg库">1. 下载JPGALLEG库</a></li>
        <li><a href="#2-编译jpgalleg库">2. 编译JPGALLEG库</a></li>
        <li><a href="#3测试jpgalleg库">3、测试JPGALLEG库</a></li>
      </ul>
    </li>
  </ul>
</nav>
  </div>
</div>
    <div class="post-content">
      <p>Allegro本身不能对jpeg图片进行处理，比如把生成的图形存储成jpeg文件，所以给Allegro配上一个合适的jpeg库是很有必要的，本文详细介绍了如何在Allegro上安装一个叫做jpgalleg的jpeg库。<strong>本文是我2008年的作品，2023年重新整理发布，仅为存档，其中的程序并没有再次验证，特此说明。</strong></p>
<h2 id="前言">前言</h2>
<blockquote>
<p>Allegro我们已经安装好了，相信应该很好用，我在实际运用中感觉Allegro最遗憾的问题是无法对JPEG图片进行处理，这给我带来了很多麻烦，比如在工控系统下，通常存储空间都很有限，比如使用FLASH memory，或者使用小容量的CF卡(因为要考虑成本)等，当要存储采集到的图片时，当然希望占用的空间越小越好，但Allegro却不能存储成JPEG格式；或者我们通过网络从服务器上获得图片，我们当然希望图片文件小一些，这样传输的可以快一些，但Allegro却不能调入JPEG文件，种种这些麻烦让我下决心找一个好用的JPEG库，好在很幸运，我找到了一个可以和Allegro完美结合的JPEG库：JPGALLEG。</p>
</blockquote>
<blockquote>
<p>本文介绍如何在已经搭建好的平台：DOS+DJGPP+ALLEGRO的环境下，安装JPGALLEG库。</p>
</blockquote>
<h2 id="1-下载jpgalleg库">1. 下载JPGALLEG库</h2>
<ul>
<li>JPGALLEG库的官方下载地址在: <code>http://wiki.allegro.cc/JpgAlleg</code>，但是这个网址现在已经失效了(2023年4月21日)；</li>
<li>好在我保留了jpgalleg 2.5，可以在 <a href="/software/jpgalleg/jpgall25.zip"><strong>这里</strong></a> 下载</li>
</ul>
<h2 id="2-编译jpgalleg库">2. 编译JPGALLEG库</h2>
<ul>
<li>由于JPGALLEG库是以源代码形式发行的，所以我们要进行编译后才可以使用。</li>
<li>将下载到的jpgall25.zip放到c:\下，键入命令：<code>unzip32 jpgall25</code></li>
<li>会在c:下建立一个新目录c:\jpgall2.5，所有的文件会被解压缩到这个目录下，如果你使用pkunzip解压缩，请不要忘记使用-d选项。</li>
<li>进入jpgall2.5目录，执行编译
<div class="highlight"><div class="chroma">
<table class="lntable"><tr><td class="lntd">
<pre tabindex="0" class="chroma"><code><span class="lnt">1
</span><span class="lnt">2
</span><span class="lnt">3
</span><span class="lnt">4
</span></code></pre></td>
<td class="lntd">
<pre tabindex="0" class="chroma"><code class="language-fallback" data-lang="fallback"><span class="line"><span class="cl">c:\&gt;cd jpgall2.5
</span></span><span class="line"><span class="cl">c:\jpgall2.5&gt;fix djgpp
</span></span><span class="line"><span class="cl">c:\jpgall2.5&gt;make
</span></span><span class="line"><span class="cl">c:\jpgall2.5&gt;make install
</span></span></code></pre></td></tr></table>
</div>
</div></li>
<li>一般情况下在执行make这一步骤时，可能会出现一些警告信息，不用管它，正常情况下，不会有问题。</li>
<li>安装完毕。</li>
</ul>
<h2 id="3测试jpgalleg库">3、测试JPGALLEG库</h2>
<ul>
<li>
<p>首先进入DJGPP安装目录下的lib下，应该可以看到一个库文件libjpgal.a，这基本说明安装成功了。</p>
</li>
<li>
<p>按照JPGALLEG库随带的readme文件看，似乎在编译时加上-ljpgal就可以使用JPGALLEG库，这是gcc的编译方法，在DOS的rhide下并不成功。</p>
</li>
<li>
<p>使用rhide工作时，为编译程序建立工程，哪怕只有一个程序也要建立一个工程（Project），并把刚编译完成的库libjpgal.a作为一个工程项目加到工程中。</p>
<ul>
<li>
<p>在rhide的做如下设置：<code>Option----&gt;Directories----&gt;Libraries----&gt;c:\djgpp\lib</code></p>
<blockquote>
<p>如下面两图：</p>
</blockquote>
<p><img src="/images/160013/add-jpgalleg-under-rhide.jpg" alt="给Allegro增加一个JPEG库"></p>
<p><img src="/images/160013/set-lib-path-under-rhide.jpg" alt="给Allegro增加一个JPEG库"></p>
</li>
</ul>
</li>
<li>
<p>当然，如果你的DJGPP不是安装在c:\djgpp目录下，请按照实际情况设置。</p>
</li>
<li>
<p>此时，我们可以进入到JPGALLEG的目录c:\jpgall2.5，在这个目录下应该可以看到一个叫examples的子目录，进入该子目录，在这个子目录下有ex1.c ex2.c ex3.c ex4.c ex5.c五个范例文件，我们试着编译其中的一个，比如ex1.c。</p>
<ul>
<li><code>c:\jpgall2.5\examples&gt;rhide ex1</code></li>
<li>将ex1.c和c:\djgpp\lib\libjpgal.a加入到工程项目中，并按照上一步的方法进行设置，由于需要Allegro库，记得参考设置Allegro的编译选项。</li>
<li>在菜单上选择：<code>Compile----&gt;Make</code></li>
</ul>
</li>
<li>
<p>应该完美地完成编译，然后你可以按Ctrl+F9运行以下，屏幕上你应该可以看到一幅漂亮的图片，就像下图：</p>
<p><img src="/images/160013/jpgalleg-logo.jpg" alt="给Allegro增加一个JPEG库"></p>
</li>
</ul>
<blockquote>
<p>至此，一切已经就绪。Enjoy it!</p>
</blockquote>
<hr>
<p><strong>欢迎访问我的博客：https://whowin.cn</strong></p>
<p><strong>email: <a href="mailto:hengch@163.com">hengch@163.com</a></strong></p>
<p><img src="https://whowin.gitee.io/images/qrcode/sponsor-qrcode.png" alt="donation"></p>
    </div>

    <div class="post-copyright">
  <p class="copyright-item">
    <span class="item-title">文章作者</span>
    <span class="item-content">whowin</span>
  </p>
  <p class="copyright-item">
    <span class="item-title">上次更新</span>
    <span class="item-content">
        2008-05-15
        
    </span>
  </p>
  
  
</div>
<footer class="post-footer">
      <div class="post-tags">
          <a href="/tags/dos/">DOS</a>
          <a href="/tags/djgpp/">DJGPP</a>
          <a href="/tags/allegro/">ALLEGRO</a>
          <a href="/tags/jpgalleg/">jpgalleg</a>
          </div>
      <nav class="post-nav">
        <a class="prev" href="/post/blog/dos/0014-install-dos-on-vbox-under-ubuntu/">
            <i class="iconfont icon-left"></i>
            <span class="prev-text nav-default">在vitual box虚拟机上安装dos</span>
            <span class="prev-text nav-mobile">上一篇</span>
          </a>
        <a class="next" href="/post/blog/dos/0012-install-allegro-under-dos-djgpp/">
            <span class="next-text nav-default">在DJGPP&#43;DOS下安装ALLEGRO</span>
            <span class="next-text nav-mobile">下一篇</span>
            <i class="iconfont icon-right"></i>
          </a>
      </nav>
    </footer>
  </article>
        </div>
        

  <span id="/post/blog/dos/0013-install-jpgalleg-for-allegro-under-djgpp/" class="leancloud_visitors" data-flag-title="给Allegro增加一个JPEG库">
		<span class="post-meta-item-text">文章阅读量 </span>
		<span class="leancloud-visitors-count">0</span>
		<p></p>
	  </span>
  <div id="vcomments"></div>
  <script src="//cdn1.lncld.net/static/js/3.0.4/av-min.js"></script>
  <script src='//unpkg.com/valine/dist/Valine.min.js'></script>
  <script type="text/javascript">
    new Valine({
        el: '#vcomments' ,
        appId: 'OFCGzCfJRUglzOdzrqMGkbTR-gzGzoHsz',
        appKey: 'v7P29kPAEbsmaavaYPNhGhnF',
        notify:  false ,
        verify:  false ,
        avatar:'mm',
        placeholder: '说点什么吧...',
        visitor:  true 
    });
  </script>

  

      </div>
    </main>

    <footer id="footer" class="footer">
      <div class="social-links">
      <a href="mailto:hengch@163.com" class="iconfont icon-email" title="email"></a>
  <a href="https://whowin.gitee.io/index.xml" type="application/rss+xml" class="iconfont icon-rss" title="rss"></a>
</div>
<div class="copyright">
  <span class="power-by">
    由 <a class="hexo-link" href="https://gohugo.io">Hugo</a> 强力驱动
  </span>
  <span class="division">|</span>
  <span class="theme-info">
    主题 - 
    <a class="theme-link" href="https://github.com/olOwOlo/hugo-theme-even">Even</a>
  </span>

  <div class="busuanzi-footer">
    <span id="busuanzi_container_site_pv"> 本站总访问量 <span id="busuanzi_value_site_pv"><img src="/img/spinner.svg" alt="spinner.svg"/></span> 次 </span>
      <span class="division">|</span>
    <span id="busuanzi_container_site_uv"> 本站总访客数 <span id="busuanzi_value_site_uv"><img src="/img/spinner.svg" alt="spinner.svg"/></span> 人 </span>
  </div>

  <span class="copyright-year">
    &copy; 
    2022 - 
    2024<span class="heart"><i class="iconfont icon-heart"></i></span><span>whowin</span>
  </span>
</div>

    </footer>

    <div class="back-to-top" id="back-to-top">
      <i class="iconfont icon-up"></i>
    </div>
  </div>
  
  <script src="https://cdn.jsdelivr.net/npm/jquery@3.2.1/dist/jquery.min.js" integrity="sha256-hwg4gsxgFZhOsEEamdOYGBf13FyQuiTwlAQgxVSNgt4=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/slideout@1.0.1/dist/slideout.min.js" integrity="sha256-t+zJ/g8/KXIJMjSVQdnibt4dlaDxc9zXr/9oNPeWqdg=" crossorigin="anonymous"></script>
  <script src="https://cdn.jsdelivr.net/npm/@fancyapps/fancybox@3.1.20/dist/jquery.fancybox.min.js" integrity="sha256-XVLffZaxoWfGUEbdzuLi7pwaUJv1cecsQJQqGLe7axY=" crossorigin="anonymous"></script>



<script type="text/javascript" src="/js/main.min.64437849d125a2d603b3e71d6de5225d641a32d17168a58106e0b61852079683.js"></script>
  <script type="text/javascript">
    window.MathJax = {
      tex: {
        inlineMath: [['$','$'], ['\\(','\\)']],
        }
    };
  </script>
  <script async src="https://cdn.jsdelivr.net/npm/mathjax@3.0.5/es5/tex-mml-chtml.js" integrity="sha256-HGLuEfFcsUJGhvB8cQ8nr0gai9EucOOaIxFw7qxmd+w=" crossorigin="anonymous"></script>








</body>
</html>
